

# Chipions'25 Phase 1 mini project Sequential 8x8 multiplier

### Objective:

Build an 8x8 multiplier. The input to the multiplier consists of two 8-bit multiplicands (dataa and datab) and the output from the multiplier is 16-bit product (product8x8\_out).

Additional outputs are a done bit (done\_flag) and seven signals to drive a 7 segment display (seg\_a, seg\_b, seg\_c, seg\_d, seg\_e, seg\_f & seg\_g).

This 8 x 8 multiplier requires four clock cycles to perform the full multiplication. During each cycle, a pair of 4-bit portion of the multiplicands is multiplied by a 4 x 4 multiplier. The multiplication result of these 4-bit slices is then accumulated. At the end of the four cycles (during the 5th cycle), the fully composed 16-bit product can be read at the output. The following equations illustrate the mathematical principles supporting this implementation:



8x8 top level design block diagram

# 16-bit adder



- Write Verilog code to perform addition.
- Write its testbench.
- Put screenshots of testbench results and circuit schematic (hint: to show schematic in Quiestasim, type vsim -debugDB adder.v in Quiestasim transcript window).

# 4x4 multiplier



- Write Verilog code to perform multiplication.
- Write its testbench.
- Put screenshots of testbench results and circuit schematic (hint: to show schematic in Quiestasim, type vsim -debugDB mult4x4.v in Quiestasim transcript window).

## 2-1 multiplexer:



- Write Verilog code to perform 2-1 mux.
- Write its testbench.
- Put screenshots of testbench results and circuit schematic (hint: to show schematic in Quiestasim, type vsim -debugDB mux4.v in Quiestasim transcript window).

### **Shifter:**



- Write Verilog code to perform 8-bit to 16-bit left shifter (hint: see equation in page 1)
- If shift\_cntrl = 0 or 3, then no shift
- If shift\_cntrl =1, then 4-bit shift left
- If shift\_cntrl = 2, then 8-bit shift left
- Write its testbench.
- Put screenshots of testbench results and circuit schematic (hint: to show schematic in Quiestasim, type vsim -debugDB shifter.v in Quiestasim transcript window).

# 7-segment display encoder:



- Write Verilog code to perform encoder as following table:

| Inputs           | Outputs |       |       |       |       |       |       | 1.55           |
|------------------|---------|-------|-------|-------|-------|-------|-------|----------------|
| inp<br>[2:0]     | seg_a   | seg_b | seg_c | seg_d | seg_e | seg_f | seg_g | LED<br>Display |
| 000              | 1       | 1     | 1     | 1     | 1     | 1     | 0     | 0              |
| 001              | 0       | 1     | 1     | 0     | 0     | 0     | 0     | 1              |
| 010              | 1       | 1     | 0     | 1     | 1     | 0     | 1     | 2              |
| 011              | 1       | 1     | 1     | 1     | 0     | 0     | 1     | 3              |
| All other values | 1       | 0     | 0     | 1     | 1     | 1     | 1     | E              |

- Write its testbench.
- Put screenshots of testbench results and circuit schematic (hint: to show schematic in Quiestasim, type vsim -debugDB seven\_segment\_cntrl.v in Quiestasim transcript window).

### Synchronous 16-bit register:



- Write Verilog code to perform synchronous 16-bit register where sclr\_n is a reset signal and clk\_ena is a clock enable signal.
- If clk\_ena is high and sclr\_n is low then the output of register is cleared.
- If clk\_ena is high and sclr\_n is high then output of register is set equal to its input.
- If clk\_ena is low then do nothing.
- Write its testbench.
- Put screenshots of testbench results and circuit schematic (hint: to show schematic in Quiestasim, type vsim -debugDB reg16.v in Quiestasim transcript window).

### 2-bit Counter with asynchronous control:



- Write Verilog code to perform 2-bit counter where aclr\_n is a reset signal
- If aclr\_n is low, then counter goes to 00 immediately
- If aclr\_n is high, output of counter increments by 1 on every rising edge clock.
- Write its testbench.
- Put screenshots of testbench results and circuit schematic

(hint: to show schematic in Quiestasim, type vsim -debugDB counter.v in Quiestasim transcript window).

# Multiplier controller



This state machine will manage all the operations that occur within the 8x8 multiplier using 6 defined states: idle, lsb, mid, msb, calc\_done, and err.

The state machine in the **LSB** state multiplies the lowest 4 bits of the two 8-bit multiplicands  $((a[3..0] * b[3..0]) * 2^0)$ . This intermediate result is saved in an accumulator.

The state machine in the **MID** state performs cross multiplication ((a[3..0] \* b[7..4]) \*  $2^4$ ) and ((a[7..4] \* b[3..0]) \*  $2^4$ ). This is done in successive clock cycles.

The products of both multiply operations are added to the content of the accumulator as they are completed and clocked back into the accumulator.

The state machine in the **MSB** state multiplies the highest 4 bits of the two 8-bit multiplicands  $((a[7..4] * b[7..4]) * 2^8)$ .

This product is added with the content of the accumulator and clocked back into the accumulator. This result is the final product:

The state machine in the CALC\_DONE state asserts the **done\_flag** output to indicate the final product has been calculated and is ready for reading by downstream logic.

The state machine in the ERR state indicates incorrect inputs have been received.

There are two inputs to the state machine: start and count. The start signal is asserted for one clock cycle to begin an 8x8 multiply operation on the next clock cycle. The start signal must only be asserted for one clock cycle. The count signal is used by the state machine to track the multiplication cycles.

The outputs of **mult\_control** state machine control the other blocks in the design.



- Write\_Verilog code to perform this state machine.
- Write its testbench.
- Put screenshots of testbench results and circuit schematic (hint: to show schematic in Quiestasim, type vsim -debugDB mult\_control.v in Quiestasim transcript window).

Finally, put all together a top-level design as shown in page 2 using instantiations required.

### **GOOD LUCK!**